package com.itheima.service.impl;

import com.github.pagehelper.Page;
import com.github.pagehelper.PageHelper;
import com.itheima.mapper.EmpExprMapper;
import com.itheima.mapper.EmpMapper;
import com.itheima.pojo.*;
import com.itheima.service.EmpLogService;
import com.itheima.service.EmpService;
import com.itheima.utils.JwtUtils;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.util.CollectionUtils;

import java.beans.Transient;
import java.time.LocalDate;
import java.time.LocalDateTime;
import java.util.*;

@Slf4j
@Service
public class EmpServiceImpl implements EmpService{
    @Autowired
    private EmpMapper empMapper;

    @Autowired
    private EmpExprMapper empExprMapper;


    private EmpLogService empLogService;
    /**
     * 原始分页查询的操作
     * @param page 当前页码
     * @param pageSize 每页显示条数
     * @return
     */
//    @Override
//    public PageResult<Emp> page(Integer page, Integer pageSize) {
//        //调用mapper接口，查询总记录数
//        Long total=empMapper.count();
//
//        //调用mapper接口，查询当前页数据
//        Integer start=(page-1)*pageSize;
//        List<Emp> rows=empMapper.list(start,pageSize);
//
//        //封装结果 PageResult
//        return new PageResult<Emp>(total,rows);
//    }


    /**
     * PageHelper分页查询
     * @return
     * 注意事项:
     *          1.定义的SQL语句结尾不能加分号;
     *          2.PageHelper仅仅能对紧跟在其后的第一个查询语句进行分页处理
     */
//    @Override
//    public PageResult<Emp> page(Integer page, Integer pageSize, String name, Integer gender, LocalDate begin, LocalDate end) {
//        //设置分页参数(PageHelper)
//        PageHelper.startPage(page,pageSize);
//
//        //执行查询
//        List<Emp> empList=empMapper.list(name,gender,begin,end);
//
//        //封装结果 PageResult
//        Page<Emp> p=(Page<Emp>)empList;
//        return new PageResult<Emp>(p.getTotal(),p.getResult());
//    }

    @Override
    public PageResult<Emp> page(EmpQueryParam empQuertParam) {
        //设置分页参数(PageHelper)
        PageHelper.startPage(empQuertParam.getPage(),empQuertParam.getPageSize());

        //执行查询
        List<Emp> empList=empMapper.list(empQuertParam);

        //封装结果 PageResult
        Page<Emp> p=(Page<Emp>)empList;
        return new PageResult<Emp>(p.getTotal(),p.getResult());
    }

    @Transactional(rollbackFor = {Exception.class})//事务管理  -- 默认出现运行时异常RuntimeException,会回滚
    @Override
    public void save(Emp emp)  {
        try {
            //保存员工基本信息
            emp.setCreateTime(LocalDateTime.now());
            emp.setUpdateTime(LocalDateTime.now());
            empMapper.insert(emp);
            //保存员工工作经历信息
            List<EmpExpr> exprList=emp.getExprList();
            //遍历集合,为empId赋值
            if(!CollectionUtils.isEmpty(exprList)){
                exprList.forEach(empExpr->{
                    empExpr.setEmpId(emp.getId());
                });
                empExprMapper.insertBatch(exprList);
            }
        } finally {

            //记录操作日志
            EmpLog empLog=new EmpLog(null,LocalDateTime.now(),"新增员工"+emp);
            empLogService.insertLog(empLog);
        }


    }

    @Transactional(rollbackFor = {Exception.class})
    @Override
    public void delete(List<Integer> ids) {
        //1.批量删除员工的基本信息
        empMapper.deleteByIds(ids);

        //2.批量删除员工的工作经历信息
        empExprMapper.deleteByEmpIds(ids);
    }

    @Override
    public Emp getInfo(Integer id) {
        return empMapper.getById(id);
    }

    @Transactional(rollbackFor = Exception.class)
    @Override
    public void update(Emp emp) {
        //1.根据ID修改员工的基本信息
        emp.setUpdateTime(LocalDateTime.now());
        empMapper.updateById(emp);
        //2. 根据ID修改员工的工作经历信息
        //2.1 现根据员工ID删除原有的工作经历
        empExprMapper.deleteByEmpIds(Arrays.asList(emp.getId()));
        //2.2 再添加这个员工新的工作经历
        List<EmpExpr> exprList=emp.getExprList();
        if(!CollectionUtils.isEmpty(exprList)){
        exprList.forEach(empExpr->empExpr.setEmpId(emp.getId()));
        empExprMapper.insertBatch(exprList);
        }
    }

    @Override
    public LoginInfo login(Emp emp) {
        //1.调用mapper接口，根据用户名和密码查询员工信息
        Emp e=empMapper.selectByUsernameAndPassword(emp);
        //2.判断:判断是否存在这个员工,如果存在,组装登录成功信息
        if(e!=null){
        log.info("登陆成功,员工信息：{}",e);
            //生成JWT令牌
            Map<String,Object> claims=new HashMap<>();
            claims.put("id",e.getId());
            claims.put("username",e.getUsername());
            String jwt= JwtUtils.generateToken(claims);
        return new LoginInfo(e.getId(),e.getUsername(),e.getName(),jwt);
}
        //3.不存在,返回null
        return null;
    }
}
